<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Day7课后作业</title>
  <style>
    span {
      user-select: none;
    }
  </style>
</head>

<body>
  <p>用户要求：名字只能包含数字、字母，数字不可以开头，长度不低于6，不长于20 [0-9 a-z A-Z]</p>
  <p>
    <label for="user">用户名</label>
    <input id="user" name="user" type="text">
    <span id="user_span"></span>
  </p>
  <p>密码6-12位 不能包含特殊字符 (弱 z/1/A 中 包含两种 强 包含三种)</p>
  <p>
    <label for="pwd">密码</label>
    <input id="pwd" name="pwd" type="text">
    <span id="pwd_span"></span>
  </p>
  <p>确认密码 两次输入相同</p>
  <p>
    <label for="repwd">确认密码</label>
    <input id="repwd" name="repwd" type="text">
    <span id="repwd_span"></span>
  </p>
  <p>随机4位验证码(点击切换验证码)</p>
  <p>
    <label for="code">验证码</label>
    <input id="code" name="code" type="text">
    <span id="random_code"></span>
    <span id="code_span"></span>
  </p>
  <button id="btn">注册</button>
</body>
<script>
  // 名字只能包含数字、字母，数字不可以开头，长度不低于6，不长于20   [0-9 a-z A-Z _$]
  // 密码6-12位  不能包含特殊字符 , 密码强弱(弱 z/1/A   中 包含两种   强 包含三种  超强 包含四种 )
  // 确认密码  两次输入相同
  // 随机4位验证码  （点击切换验证码）

  var oBtn = document.getElementById("btn");
  var oUser = document.getElementById("user");
  var oUserSpan = document.getElementById("user_span");

  var source = lowerArr().concat(upperArr(), numArr());
  // console.log(source);

  oBtn.onclick = function () {
    // alert(666);
    var username = oUser.value;//拿值，将值赋值给username

    // console.log(username,typeof username);//检验是否拿到值，且看这个值是什么类型
    // 名字只能包含数字、字母，数字不可以开头，长度不低于6，不长于20 
    if (username.length < 6 || username > 20) {
      oUserSpan.innerHTML = '用户名长度错误'
      oUserSpan.style.color = 'red'
      return
    }
    if (!isNaN(username.charAt(0))) {
      oUserSpan.innerHTML = '用户名不能以数字开头哦'
      oUserSpan.style.color = 'red'
      return
    }
    for (i = 0; i < username.length; i++) {
      if (!source.includes(username[i])) {
        oUserSpan.innerHTML = '用户名不能含有非法字符哦'
        oUserSpan.style.color = 'red'
        return
      }
    }
  }







  function lowerArr() {
    var list = [];
    for (var i = 97; i <= 122; i++) {
      list.push(String.fromCharCode(i));
    }
    return list;
  }
  function upperArr() {
    var list = [];
    for (var i = 65; i <= 90; i++) {
      list.push(String.fromCharCode(i));
    }
    return list;
  }
  function numArr() {
    var list = [];
    for (var i = 48; i <= 57; i++) {
      list.push(String.fromCharCode(i));
    }
    return list;
  }


</script>

</html>